package com.bzkj.document.mapper;

import cn.hutool.core.lang.hash.Hash;
import com.bzkj.document.domain.materialout.dto.MaterialOutboundDTO;
import com.bzkj.document.domain.materialout.vo.MaterialOutboundBodyVo;
import com.bzkj.document.domain.materialout.vo.MaterialOutboundHeaderVo;
import org.apache.ibatis.annotations.Param;

import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @projectName: prt-wms
 * @package: com.bzkj.document.mapper
 * @className: MaterialOutboundMapper.xml
 * @description: 材料出库单持久层
 * @author: C1309
 * @createDate: 2024年12月09日
 * @version: v1.0
 */
public interface MaterialOutboundMapper {

    /**
     * 获取材料出库单据状态
     *
     * @param cgeneralhid 单据头信息
     * @return 单据状态
     */
    HashMap<String, String> getBillStatus(String cgeneralhid);

    /**
     * 更新材料出库单据状态
     *
     * @param cgeneralhid 单据头信息
     * @param billState   状态信息
     * @param userName    用户名
     * @param reason      作废原因（当单据状态为作废时，必填）
     * @return 操作结果
     */
    int updateBillState(@Param("cgeneralhid") String cgeneralhid,
                        @Param("billState") String billState,
                        @Param("userName") String userName,
                        @Param("reason") String reason);

    /**
     * 更新材料出库单据头信息
     *
     * @param header 单据头
     * @return 操作结果
     */
    int updateMaterialOutboundOrder(Map<String, Object> header);

    /**
     * 更新材料出库明细信息
     *
     * @param detailMap 明细信息
     * @return 操作结果
     */
    int updateMaterialOutboundOrderDetails(HashMap<String, Object> detailMap);

    /**
     * 新增材料出库单表头
     *
     * @param header 表头信息
     * @return 操作结果
     */
    int addMaterialOrderHeader(Map<String, Object> header);

    /**
     * 新增材料出库单明细
     *
     * @param detailMap 明细信息
     * @return 操作结果
     */
    int addMaterialOrderDetails(Map<String, Object> detailMap);

    /**
     * 查询本地已经确认的材料出库单表头
     *
     * @param materialOutboundDTO 查询条件
     * @return 结果集
     */
    List<MaterialOutboundHeaderVo> selectLocalMaterialOutboundOrderHeader(MaterialOutboundDTO materialOutboundDTO);

    /**
     * 查询本地已经确认的材料出库单表头
     *
     * @param cgeneralhid 查询条件
     * @return 查询结果
     */
    MaterialOutboundHeaderVo selectLocalMaterialOutboundOrderHeaderByBillCode(@Param("cgeneralhid") String cgeneralhid);

    /**
     * 查询本地已经确认的材料出库单明细
     *
     * @param cgeneralhid NCC单据编号
     * @param billState  单据状态
     * @return 查询结果集
     */
    List<MaterialOutboundBodyVo> queryMaterialOrderDetails(@Param("cgeneralhid") String cgeneralhid,
                                                           @Param("billState") String billState);

    /**
     * 判断单据是否已经存在
     *
     * @param vbillcode NCC单据编号
     * @return 查询结果
     */
    int selectIsExist(String vbillcode);

    /**
     * 撤回材料出库单表头
     *
     * @param headerId 材料出库单表头ID
     * @param userName 用户名
     * @return 操作结果
     */
    int orderBackHead(@Param("headerId") String headerId, @Param("userName") String userName);

    /**
     * 撤回材料出库单明细
     *
     * @param headerId 材料出库单表头ID
     * @param userName 用户名
     * @return 操作结果
     */
    int orderBackDetails(@Param("headerId") String headerId, @Param("userName") String userName);
}
